<?php

/*
 * Table/TitreSejourTable.php
 */

namespace RHX\Model\Table;

use Zend\Db\Adapter\Adapter;
use Zend\Db\TableGateway\AbstractTableGateway;
use Zend\Db\ResultSet\ResultSet;
use Zend\Db\Sql\Select;
use RHX\Model\Object\TitreSejour;

class TitreSejourTable extends AbstractTableGateway {

    /**
     *
     * @var string Nom de la table
     */
    protected $table = 'rh_titre_sejour';

    public function __construct(Adapter $adapter) {
	$this->adapter			 = $adapter;
	$this->resultSetPrototype	 = new ResultSet();
	$this->resultSetPrototype->setArrayObjectPrototype(new TitreSejour());
	$this->initialize();
    }

    /**
     * Tous les titres de séjour
     *
     * @return array
     */
    public function getAll() {
	return $this->select(function(Select $select) {
			    $select->order('id ASC');
			});
    }

    /**
     * Récupérer un titre de séjour
     *
     * @param int $id
     * @return TitreSejour
     * @throws \Exception
     */
    public function get($id) {
	$row = $this->select(array('id' => $id))
		->current();
	if (!$row) {
	    throw new \Exception("Impossible de trouver le titre de séjour #$id");
	}

	return $row;
    }

    /**
     * Effacer un titre de séjour
     *
     * @param int $id
     * @return int Nombre d'enregistrement effacé
     */
    public function erase($id) {
	return $this->delete(array('id' => $id));
    }

    /**
     * Sauvegarder un titre de séjour
     *
     * @param \RHX\Model\Object\TitreSejour $titre
     * @return int Identifiant du titre de séjour
     * @throws \Exception
     */
    public function save(TitreSejour $titre) {
	$data	 = array(
	    'libelle'	 => $titre->libelle,
	    'description'	 => $titre->description,
	);
	$id	 = (int) $titre->id;
	if ($id == 0) {
	    $this->insert($data);

	    return $this->getLastInsertValue();
	}
	elseif ($this->get($id)) {
	    $this->update($data, array('id' => $id));

	    return $id;
	}
	else {
	    throw new \Exception("Impossible de séléction le titre de séjour #$id");
	}
    }

}

?>
